package com.cdut.cn.boke.interceptor;


import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.servlet.http.HttpSession;
import org.springframework.web.servlet.HandlerInterceptor;

/**
 * HandlerInterceptor实现拦截器接口
 */
public class AuthInterceptor implements HandlerInterceptor {
    /**
     * 请求处理前进行操作
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        if (request.getRequestURI().equals("/")) {//放行首页
            return true;
        }

        HttpSession session = request.getSession();//获取session对象
        //从会话中获取数据 用户名
        String username = (String) session.getAttribute("username");//从session对象获取用户名

        // 检查会话中是否存在用户名来决定用户是否已经登录
        if (username != null) {
            return true; // 已登录 放行
        } else {
            response.sendRedirect("/admin/login"); // 未登录则重定向到登录页面
            return false;
        }
    }
}